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INVENTORS: S, G. Hild and K. Singhal 



METHOD AND APPARATUS FOR AUTOMATED TRANSCODER 

SELECTION 

1. Field of the Invention: 

The present invention relates generally to an improved 
data processing system, and in particular to a method and 
apparatus for transferring data between different data 
processing systems. Still more particularly, the present 
invention provides a method and apparatus for selecting a 
transcoder for use in translating content. 

2. Background of the Invention: 

Today, computing functions traditionally found only in 
desktop or laptop personal computers are being integrated 
into many different types of devices. For example, personal 
digital assistants (PDAs) , such as the Palm Pilot (available 

Docket No. RSW9-2000-0075-US1 



from Palm Computing, Inc.), now often provide for web 
browsing functions and can be connected to the Internet using 
wireless modems. These same PDAs can be used to access and 
download e-mail, as well as execute various custom 
applications. Browsing capabilities and e-mail access are 
also found in digital wireless phones such as those 
communicating using the Wireless Application Protocol (WAP) . 
Computing power also is being introduced into home 
appliances, such as refrigerators. Other examples of 
pervasive computing devices include automotive computers that 
provide browsing, messaging, and emergency communications 
capabilities; screen phones that mix Web access with voice 
communications; and Web-enabled televisions that support 
interactive television programming and Web access. 

Pervasive computing aims at enabling a diverse range of 
devices to access an equally diverse range of data servers. 
Presently, different types of devices require different types 
of data format because no one universally accepted content 
format is present. Instead, a variety of content formats, 
such as, for example. Hypertext Markup Language (HTML), 
Wireless Markup Language (WML) , Compact HTML (cHTML) , VoxML, 
and VoiceXML are used in different markets or device classes. 
Presently, content providers are forced to maintain and 
operate a number of separate servers or server infrastructure 
elements in which each of these servers or elements provides 
content and applications for different supported content 
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formats. Such a requirement is costly and burdensome for 
content providers. 

One potential solution to this problem involves the use 
of transcoders. A transcoder is an infrastructure element 
5 that sits between a content source and a device. This 

element is capable of "translating" content from one format 
into another, such as the content format delivered by the 
server into the content format expected by the device. This 
solution, however, requires significant investment in 
iQ creating transcoders, installing them, and configuring an 

appropriate rule base that determines which transcoders to 
S apply to a particular client request and server content. In 

most existing transcoding systems, generic transcoders are 
ril used to convert various server-generated content types into 

Ife the client -supported content types. These generic 

y transcoders are cheapest to develop, may be used across a 

large range of content sources, and can support all devices 
O of a particular type. However, because these transcoders are 

only associated with the source and target content types, 
20 they cannot take advantage of any special formatting or 

features present in the particular source content. Moreover, 
these transcoders cannot take advantage of any special 
capabilities present in the client device, nor can they 
address preferences of the particular user. The alternative 
25 approach is to develop specific transcoders for different 

types of applications or devices or for different individual 
users. A particular transcoder of this type is limited in 
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the types of content sources, users, or devices that it can 
handle. A resulting system must therefore include many such 
transcoders, which increases the overall implementation cost, 
maintenance cost, and system complexity. 

Therefore, it would be advantageous to have an improved 
method and apparatus for translating content generated by a 
particular server or application from its source format into 
a format for use by a target device and a user. 



Docket No. RSW9-2000-0075-US1 



5 



SUMMARY OF THE INVENTION 

The present invention provides a method in a data 
processing system for transcoding content using a set of 
transcoders. A request is received for the content from a 
client, wherein the request includes a set of 
characteristics, A transcoder is selected from the set of 
transcoders having a best match to the set of 
characteristics. The content is transcoded using the 
transcoder to form transcoded content. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



The novel features believed characteristic of the 
invention are set forth in the appended claims. The 
invention itself, however, as well as a preferred mode of 
use, further objectives and advantages thereof, will best be 
understood by reference to the following detailed description 
of an illustrative embodiment when read in conjunction with 
the accompanying drawings, wherein: 

Figure 1 depicts a pictorial representation of a 
distributed data processing system in which the present 
invention may be implemented; 

Figure 2 is a block diagram of a data processing system 
that may be implemented as a server in accordance with a 
preferred embodiment of the present invention; 

Figure 3 is a block diagram of a client in accordance with 
a preferred embodiment of the present invention; 

Figure 4 is a block diagram illustrating selection of a 
transcoder for a request in accordance with a preferred 
embodiment of the present invention; 

Figure 5 is a diagram of a table of transcoder and tuple 
associations in accordance with a preferred embodiment of the 
present invention; and 

Figure 6 is a flowchart of a process used for automated 
transcoder selection in accordance with a preferred embodiment 
of the present invention. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 



With reference now to the figures. Figure 1 depicts a 
pictorial representation of a distributed data processing 
system in which the present invention may be implemented. 
Distributed data processing system 100 is a network of 
computers in which the present invention may be implemented. 
Distributed data processing system 100 contains a network 102, 
which is the medium used to provide communications links 
between various devices and computers connected together within 
distributed data processing system 100. Network 102 may include 
permanent connections, such as wire or fiber optic cables, or 
temporary connections made through telephone connections. 

In the depicted example, a server 104 is connected to 
network 102 along with storage unit 106. In addition, clients 
108, 110, and 112 also are connected to network 102. These 
clients 108, 110, and 112 may be, for example, personal 
computers or network computers. For purposes of this 
application, a network computer is any computer, coupled to a 
network, which receives a program or other application from 
another computer coupled to the network. Clients 114 and 116 
in these examples are pervasive devices, which communicate 
using wireless communication links. Clients 114 and 116 may 
be, for example, PDAs or some other hand- held computing device. 
Although these clients communicate with network 102 using 
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wireless links, a physical connection, such as a phone line or 
Ethernet connection may be used. 

In the depicted example, server 104 provides data, such as 
boot files, operating system images, and applications to 
clients 108-116. Clients 108-116 are clients to server 104. 
Distributed data processing system 100 may include additional 
servers, clients, and other devices not shown. In the depicted 
example, distributed data processing system 100 is the Internet 
with network 102 representing a worldwide collection of 
networks and gateways that use the TCP/IP suite of protocols to 
communicate with one another. At the heart of the Internet is 
a backbone of high-speed data communication lines between major 
nodes or host computers, consisting of thousands of commercial, 
government, educational and other computer systems that route 
data and messages. Of course, distributed data processing 
system 100 also may be implemented as a number of different 
types of networks, such as for example, an intranet, a local 
area network (LAN) , and or a wide area network (WAN) . These 
networks also include mechanisms for wireless communications 
links in these examples. Figure 1 is intended as an example, 
and not as an architectural limitation for the present 
invention. 

Referring to Figure 2, a block diagram of a data 
processing system that may be implemented as a server, such as 
server 104 in Figure 1, is depicted in accordance with a 
preferred embodiment of the present invention. The processes 
of the present invention are implemented in a server, such as 
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data processing system 200 in these examples. Data processing 
system 200 may be a symmetric multiprocessor (SMP) system 
including a plurality of processors 202 and 204 connected to 
system bus 206. Alternatively, a single processor system may 
be employed. Also connected to system bus 206 is memory 
controller/cache 208, which provides an interface to local 
memory 209. I/O bus bridge 210 is connected to system bus 206 
and provides an interface to I/O bus 212. Memory 
controller/cache 208 and I/O bus bridge 210 may be integrated 
as depicted. 

Peripheral component interconnect (PCI) bus bridge 214 
connected to I/O bus 212 provides an interface to PCI local bus 
216. A number of modems may be connected to PCI bus 216. 
Typical PCI bus implementations will support four PCI expansion 
slots or add-in connectors. Communications links to network 
computers 108-112 in Figure 1 may be provided through modem 218 
and network adapter 22 0 connected to PCI local bus 216 through 
add- in boards . 

Additional PCI bus bridges 222 and 224 provide interfaces 
for additional PCI buses 226 and 228, from which additional 
modems or network adapters may be supported. In this manner, 
data processing system 200 allows connections to multiple 
network computers. A memory-mapped graphics adapter 230 and 
hard disk 232 may also be connected to I/O bus 212 as depicted, 
either directly or indirectly. 

Those of ordinary skill in the art will appreciate that 
the hardware depicted in Figure 2 may vary. For example, other 
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peripheral devices, such as optical disk drives and the like, 
also may be used in addition to or in place of the hardware 
depicted. The depicted example is not meant to imply 
architectural limitations with respect to the present 
invention. 

The data processing system depicted in Figure 2 may be, 
for example, an IBM RISC/System 6000 system, a product of 
International Business Machines Corporation in Armonk, New 
York, running the Advanced Interactive Executive (AIX) 
operating system. 

Turning next to Figure 3, a block diagram of a client is 
depicted in accordance with a preferred embodiment of the 
present invention. In this example, data processing system 300 
is an example of a client, such as client 108 or client 116 in 
Figure 1. Data processing system 300 includes a bus 302, which 
interconnects and provides communication between processing 
unit 304, storage device 306, input/output (I/O) unit 308, and 
communications unit 310. Processing unit 304 may include one 
or more processors and executes instructions located in storage 
device 306. Storage device 306 contains instructions for 
performing various functions as well as data and may take 
various forms depending on the type of client. For example, 
storage device 306 may be a random access memory (RAM) , a read- 
only memory (ROM) , a non-volatile RAM (NVRAM) , or a hard disk 
drive. I/O unit 308 provides interactive with data processing 
system 300 and typically includes a display device as well as 
an input device, such as a keyboard, touchpad, mouse, or touch 
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screen. Communications unit 310 provides for exchanging data 
with other systems. Communications unit 310 may take various 
forms, such as, for example, a wireless modem or a network 
adapter. Data processing system 300 may take many forms, such 
as, for example, a PDA, kiosk, laptop computer, or a palm top 
computer. 

The present invention provides a method, apparatus, and 
computer implemented instructions for translating content from 
a source format to a target format. The mechanism of the 
present invention allows for the use of both specific and 
generic transcoders based on a particular request from a 
client. The mechanism of the present invention allows for 
generic transcoder plug- ins with specific transcoder plug- ins 
(which are appropriate for a particular application, client 
device, and/or user) in a manner allowing a particular request 
to be handled by the most specific transcoding engine 
available. In this manner, specific transcoders may be used 
when available, but generic transcoders are used when specific 
ones are not available. 

Turning next to Figure 4, a block diagram illustrating 
selection of a transcoder for a request is depicted in 
accordance with a preferred embodiment of the present 
invention. In this example, client 400 sends a request to 
server 402 for content located in content database 404. Though 
not shown in Figure 4, content database 404 may be located on a 
separate server and accessed by means of a direct database 
request or by means of a Web server request delivered over 
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HTTP, WSP, or some other protocol. Also, the content delivered 
from this content database 404 may be generated dynamically, 
for example, by means of server-side applications such as Java 
servlets. Common- Gateway Interface (CGI) programs, Active 
Server Pages (ASPs) , or JavaServer Pages, This request is 
processed by server request process 406. When the request is 
received, a transcoder is selected from transcoders 408 to 
translate content from content database 404 into a format for 
use by client 400. This selection of transcoders is performed 
using a transcoder table 410 to identify the appropriate 
transcoder from transcoders 408 to translate content from 
content database 404 into a desired or target content. 

In these examples, the request received from client 400 is 
represented as a tuple of parameters containing a document type 
definition (DTD) , an application, a device, and a user. The 
DTD defines the type of document, such as HTML or WML, 
requested by the client. The application identifies the type 
of application that is to receive the content, such as a mail 
program or a web browser. The device is used to identify the 
type of device that the content is to be processed or displayed 
on, such as, for example, a PDA or a desktop computer. The 
user name may be used to identify a specific user. A 
transcoder for a specific user may account for the user's 
particular color preferences, for example, screen layout 
preferences, or sound choices. Of course, other information 
may be included in the request to select a transcoder. For 
example, a network identification also may be included. Each 
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transcoder in transcoders 408 is associated with a tuple with 
these associations being stored in transcoder table 410 in 
these examples. 

The tuple associated with a transcoder may include a wild 
card or an absence of a particular parameter to indicate that 
that parameter is not specified for a particular transcoder. 
Server request process 406 performs a hierarchical search to 
find the most specific translator present for the request. In 
these examples, the search is initiated from most specificity 
to least specificity as follows: (DTD, application, device, 
user), {DTD, application, device, *) , (DTD, application, *, *) , 
(DTD, *, *, *), and (*, *, device, *) with indicating a 

wild card. Alternative embodiments of the present invention 
may define different search templates and different orderings 
of these search templates to identify the most specific 
transcoder to apply to the particular request. In this manner, 
server request process 406 attempts to locate a transcoder 
exactly matching a particular application for a particular user 
and device. If such a transcoder is absent, server request 
process 406 then looks for an application specific transcoder 
for the device. If such a transcoder is absent, then a generic 
transcoder for the device is selected for use in translating 
the content . 

Referring now to Figure 5, a diagram of a table of 
transcoder and tuple associations are depicted in accordance 
with a preferred embodiment of the present invention. In this 
example, table 500 is an example of a table, such as transcoder 
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table 410 in Figure 4. Table 500 includes tuples in column 502 
and transcoders in column 504. Depending on the specificity of 
the request, a specific transcoder, such as transcoder 1 in 
column 504 may be selected or a more generic transcoder, such 
as transcoder 6 may be selected for use in translating content 
for the client. 

Turning next to Figure 6, a flowchart of a process used 
for automated transcoder selection is depicted in accordance 
with a preferred embodiment of the present invention. The 
process illustrated in Figure 6 may be implemented in a server 
request process, such as server request process 406 in Figure 4 
to automatically select a transcoder in response to receiving a 
request for content. 

The process begins by receiving a request from a client 
(step 600) . In these examples, the request includes a DTD, an 
application, a device, and a user in addition to an 
identification of the content desired by the client. These 
parameters are identified (step 602) . A search for the 
particular DTD, device, and user is made (step 604) . This 
search is made in a transcoder table, such as transcoder table 
410 in Figure 4. A determination is made as to whether a match 
is found (step 606) . If a match is absent, a search for a more 
generic transcoder is performed based on DTD, application, and 
device from the request (step 608) . A determination is made as 
to whether a transcoder matching these parameters is present 
(step 610) . If a transcoder is absent for these parameters, a 
search using the DTD and the application is made (step 612) . A 
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determination is made as to whether a transcoder matching the 
particular DTD and application is present (step 614) . If a 
match is absent, then a search using just the device type is 
made (step 616) , A determination is made as to whether a 
transcoder matching the particular device is present (step 
618) . If no transcoder is found, then the unmodified content 
(or, in an alternative embodiment, an error) is returned to the 
user (step 620) with the process terminating thereafter. With 
reference again to steps 606, 610, 614, and 618, if a match is 
found in any of these searches, the identified transcoder is 
used to translate the content (step 622) with the process then 
proceeding to step 620 as described above. 

Thus, the present invention provides an improved method 
and apparatus for automatically selecting a transcoder for 
translating content for a client. The mechanism of the present 
invention attempts to locate a transcoder using a hierarchical 
search to look for the most specific transcoder available for 
the request. The selection of the transcoder is based on the 
request and in particular based on the parameters included in 
the request. The mechanism of the present invention allows for 
a mixing of generic transcoders with more specific ones. In 
this manner, specific transcoders may be developed as needed or 
warranted while generic transcoders are available in the 
absence of a more specific one. 

It is important to note that while the present invention 
has been described in the context of a fully functioning data 
processing system, those of ordinary skill in the art will 
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appreciate that the processes of the present invention are 
capable of being distributed in the form of a computer 
readable medium of instructions and a variety of forms and 
that the present invention applies equally regardless of the 
particular type of signal bearing media actually used to 
carry out the distribution. Examples of computer readable 
media include recordable -type media such a floppy disc, a 
hard disk drive, a RAM, CD-ROMs, and transmission- type media 
such as digital and analog communications links. 

The description of the present invention has been 
presented for purposes of illustration and description, and 
is not intended to be exhaustive or limited to the invention 
in the form disclosed. Many modifications and variations will 
be apparent to those of ordinary skill in the art. The 
embodiment was chosen and described in order to best explain 
the principles of the invention, the practical application, 
and to enable others of ordinary skill in the art to 
understand the invention for various embodiments with various 
modifications as are suited to the particular use 
contemplated. 
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CLAIMS : 

What is claimed is: 

1 y/ A method in a data processing system for transcoding 

2 content using a set of transcoders, the method comprising: 

3 receiving a request for the content from a client, 

4 wherein the request includes a set of characteristics; 

5 selecting a transcoder from the set of transcoders 

6 having a best match to the set of characteristics; and 

ffi transcoding the content using the transcoder to form 

transcoded content. 

^aj 2„ The method of claim 1 further comprising: 

'% sending the transcoded content to the client. 

gi 3. The method of claim 1, wherein the set of 

characteristics includes a content type and a set of client 

% characteristics . 

1 4. The method of claim 1, wherein the set of 

2 characteristics is a tuple including parameters for a 

3 document type definition, an application, a device, and a 

4 user. 

1 5. The method of claim 1, wherein the client is one of a 

2 personal digital assistant, a laptop computer, and a personal 

3 computer. 
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1 ^ A method in a data processing system for transcoding 

2 content using a set of transcoders, the method comprising: 

3 receiving a request for the content, wherein the request 

4 includes identification information for a client originating 

5 the request; 

6 selecting a transcoder from the set of transcoders, 

7 wherein the transcoder provides a closest match to the 

8 identification information; and 

9 processing the content using the transcoder. 

1 7. The method of claim 6, wherein the identification 

2 information comprises a content type and a set of client 

3 characteristics . 

'§ 8. The method of claim 6, wherein the identification 

m information comprises a document type definition, an 

Si application, a device, and a user. 

-1 9. The method of claim 6 further comprising: 

f2. sending the transcoded content to the client. 

m 10. The method of claim 6, wherein the client is one of a 

H personal digital assistant, a laptop computer, and a personal 

3 computer. 

1 A data processing system comprising: 

2 a bus system; 

3 a communications unit connected to the bus system; 
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4 a memory connected to the bus system, wherein the memory 

5 includes as set of instructions; and 

6 a processing unit connected to the bus system, wherein 

7 the processing unit executes the set of instructions to 

8 receive a request for the content from a client through the 

9 communications unit in which the request includes a set of 

10 characteristics, select a transcoder from the set of 

11 transcoders have a best match to the set of characteristics, 

12 and transcode the content using the transcoder to form 

13 transcoded content - 

^% 12, The data processing system of claim 11, wherein the bus 

^ system is a single bus, 

3 13. The data processing system of claim 11, wherein the bus 
system includes a primary bus and a secondary bus. 



J:| 14. The data processing system of claim 11, wherein the 

y processing unit includes a plurality of processors, 

"l 15. The data processing system of claim 11, wherein the 

2 communications unit is one of a modem and Ethernet adapter. 

1 ye . A data processing system for transcoding content using a 

2 set of transcoders, the data processing system comprising: 

3 receiving means for receiving a request for the content 

4 from a client, wherein the request includes a set of 

5 characteristics ; 
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6 selecting means for selecting a transcoder from the set 

7 of transcoders having a best match to the set of 

8 characteristics ; and 

9 transcoding means for transcoding the content using the 
10 transcoder to form transcoded content. 

1 17, The data processing system of claim 16 further 

2 comprising: 

3 sending means for sending the transcoded content to the 

4 client. 

f| 18. The data processing system of claim 16, wherein the set 

^ of characteristics includes a content type and a set of 

£§ client characteristics. 

% 19. The data processing system of claim 16, wherein the set 

^■2 of characteristics is a tuple including parameters for a 

□ document type definition, an application, a device, and a 

fi user. 

1 20. The data processing system of claim 16, wherein the 

2 client is one of a personal digital assistant, a laptop 

3 computer, and a personal computer. 

1 2^. A data processing system for transcoding content using a 

2 set of transcoders, the data processing system 

3 comprising: 
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4 receiving means for receiving a request for the content, 

5 wherein the request includes identification information for a 

6 client originating the request; 

7 selecting means for selecting a transcoder from the set 

8 of transcoders, wherein the transcoder provides a closest 

9 match to the identification information; and 

10 processing means for processing the content using the 

11 transcoder. 

1 22. The data processing system of claim 21, wherein the 

2 identification information comprises a content type and a set 
of client characteristics. 

Og 23. The data processing system of claim 21, wherein the 

^ identification information comprises a document type 
definition, an application, a device, and a user. 

% 24. The data processing system of claim 21 further 

g comprising: 

^ sending means for sending the transcoded content to the 

4"' client . 

1 25. The data processing system of claim 21, wherein the 

2 client is one of a personal digital assistant, a laptop 

3 computer, and a personal computer. 

1 ^ . A computer program product in a computer readable medium 

2 for use in a data processing system for transcoding content 
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using a set of transcoders, the computer program product comprising: 



4 first instructions for receiving a request for the 

5 content from a client, wherein the request includes a set of 

6 characteristics ; 

7 second instructions for selecting a transcoder from the 

8 set of transcoders having a best match to the set of 

9 characteristics ; and 

10 third instructions for transcoding the content using the 

11 transcoder to form transcoded content. 

1 2/^ A computer program product in a computer readable medium 

9 for use in a data processing system for transcoding content 

01 using a set of transcoders, the computer program product 

X comprising: 

^ first instructions for receiving a request for the 

m content, wherein the request includes identification 

[7 information for a client originating the request; 
S second instructions for selecting a transcoder from the 

^ set of transcoders, wherein the transcoder provides a closest 
match to the identification information; and 

11 third instructions for processing the content using the 

12 transcoder. 
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ABSTRACT OF THE DISCLOSURE 

METHOD AND APPARATUS FOR AUTOMATED TRANSCODER SELECTION 

A method and apparatus for automated transcoder 
selection in a data processing system for transcoding content 
5 using a set of transcoders. A request is received for the 

content from a client, wherein the request includes a set of 
characteristics, A transcoder is selected from the set of 
transcoders having a best match to the set of 
characteristics. The content is transcoded using the 
10 transcoder to form transcoded content. 
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IBM Docket No. RSW9-2000-0075-US1 

DECLARATION AND POWER OF ATTORNEY 
FOR PA TENTAPPLICA TION 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; I believe I am an original, 
first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention 
entitled: 

Method and Apparatus for Automated Transcoder Selection 

the specification of which is identified by the attorney (IBM) Docket Number appearing above. 

I hereby state that I have reviewed and understand the contents of the above- identified specification, including 
the claims. 

I acknowledge the duty to disclose information which is material to the patentability of this application in 
accordance with Title 37, Code of Federal Regulations, §1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, §1 19 of any foreign application(s) for 
patent or inventor's certificate listed below and have also identified below any foreign application for patent or 
inventor's certificate having a filing date before that of the application on which priority is claimed: 

Prior Foreign Application(s) 

Number Country Dav/Month/Year Priority Claimed 



I hereby claim the benefit (a) under Title 35, United States Code, §1 19(e) of any U.S. appUcation listed below 
and identified as a provisional application or (b) under Title 35, United States Code, §120 of any U.S. 
application listed below and not identified as a provisional application, and, insofar as the subject matter of each 
of the claims of this application is not disclosed in the prior U.S. application in the manner provided by the first 
paragraph of Title 35, United States Code, §1 12, 1 acknowledge the duty to disclose information material to the 
patentability of this appHcation as defined in Title 37, Code of Federal Regulations, §1.56 which occurred 
between the filing date of the prior application and the national or PCT international filing date of this 
application 

Prior U.S. Applications 
Serial No. Filing Date Status 



I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge 
that willfiil false statements and the like so made are punishable by fine or imprisonment, or both, under Section 
1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of 
the application or any patent issued thereon. 
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As a named inventor, I hereby appoint the following attorneys and/or agents to prosecute this application and 
transact all business in the Patent and Trademark Office connected therewith: 

A. Bruce Clay, Reg, No. 32,121; Gregory M. Doudnikoff, Reg. No. 32,847; Edward H. Duffield, Reg. No. 
25,970; Jerry W. Hemdon, Reg. No. 27,901; Gerald R. Woods, Reg. No. 24,144; Jeanine S. Ray-Yarletts, Reg. 
No. 39,808; Joseph C. Redmond, Jr., Reg. No. 18,753; John E. Hoel, Reg. No. 26,279; Christopher A. Hughes. 
Reg. No. 26,914; and Edward A. Pennington, Reg. No. 32,588; 



Send all correspondence to: A. Bruce Clay, IBM Corporation T81/Q^; PO Box 12195; Research Triangle Park 
NC 27709. 



AND also. 



5Q? 



5 n ii Stefan Georg Hild 



Signature: 



Date 



Residence: Zurich, Switzerland 



Citizenship: German 

Post Office Address: Austrasse 27, 8 1 34 Adliswil 
Zurich, Switzerland 




g^^$Mpt&t: Sandeep K. Singhal 




Signature: 



Date 



Residence: 2 Leighton Street 

Englewood Cliffs, New Jersey 07632-1414 



Citizenship: USA 



Post Office Address: Same 
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DECLARATION AND POWER OF ATTORNEY 
FOR PATENT APPLICATION 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; I believe I am an original, 
first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention 
entitled: 

Method and Apparatus for Automated Transcoder Selection 

the specification of which is identified by the attorney (IBM) Docket Number appearing above. 

I hereby state that I have reviewed and understand the contents of the above- identified specification, including 
the claims. 

I acknowledge the duty to disclose information which is material to the patentability of this application in 
accordance with Title 37, Code of Federal Regulations, §1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, § 119 of any foreign application(s) for 
patent or inventor's certificate listed below and have also identified below any foreign application for patent or 
inventor's certificate having a filing date before that of the application on which priority is claimed: 

Prior Foreign Application(s) 

Number Country Dav/MonthA^ear Prioritv Claimed 



I hereby claim the benefit (a) under Title 35, United States Code, §1 19(e) of any U.S. application listed below 
and identified as a provisional application or (b) under Title 35, United States Code, §120 of any U.S. 
application listed below and not identified as a provisional application, and, insofar as the subject matter of each 
of the claims of this application is not disclosed in the prior U.S. application in the manner provided by the first 
paragraph of Title 35, United States Code, § 1 12, 1 acknowledge the duty to disclose information material to the 
patentability of this application as defined in Tide 37, Code of Federal Regulations, §1.56 which occurred 
between the filing date of the prior application and the national or PCT international filing date of this 
application 

Prior U.S. Applications 
Serial No. Filing Date Status 



I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge 
that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 
1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of 
the application or any patent issued thereon. 



As a named inventor, I hereby appoint the following attorneys and/or agents to prosecute this application and 
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transact all business in the Patent and Trademark Office connected therewith: 

A. Bruce Clay, Reg, No. 32,121; Gregory M. Doudnikoff, Reg. No. 32,847; Edward H. Duffield, Reg. No. 
25,970; Jerry W. Hemdon, Reg. No. 27,901; Gerald R. Woods, Reg. No. 24,144; Jeanine S. Ray-Yarletts, Reg. 
No. 39,808; Joseph C. Redmond, Jr., Reg. No. 18,753; John E. Hoel, Reg. No. 26,279; Christopher A. Hughes, 
Reg, No. 26,914; and Edward A. Pennington, Reg. No. 32,588; 

AND also. 

Send all correspondence to: A. Bruce Clay, IBM Corporation T81/^P0 Box 12195; Research Triangle Park, 
NC 27709. 




Signature: 



Residence: Zurich, Switzerland 
Citizenship: German 

Post Office Address: Austrasse 27, 8 1 34 Adliswil 
Zurich, Switzerland 



SedoM tnvenioH i 



Sandeep K. Singhal 



Signature: 



Residence: 
Citizenship: USA 
Post Office Address: 



tMrdiHvent&r: 



Signature: 



Date 



Date 



Date 



Residence: 
Citizenship: 
Post Office Address: 



2 



United States Patent & Trademark Office 

Office of Initial Patent Examination -- Scanning Division 




Application deficiencies were found during scanning: 

□ Page(s) j of l^ilA-miiO were not pr 

for scanning. (Document title) 



□ Page(s) of were not pr 

for scannins. (Document title) 



□ Scanned copy is best available. 



